package it.gat.webservice.resource.impl;

import java.sql.SQLException;

import org.restlet.resource.Delete;
import org.restlet.resource.Get;
import org.restlet.resource.Post;
import org.restlet.resource.Put;
import org.restlet.resource.ServerResource;

import it.gat.dao.ContrattoDAO;
import it.gat.model.Contratto;
import it.gat.util.dao.DAOFactory;
import it.gat.webservice.utils.Impostazioni;

public class ContrattoResource extends ServerResource{
	
	@Post
	public void insert(Contratto contratto) {
		DAOFactory daoFactory = DAOFactory.getDAOFactory(Integer.parseInt(Impostazioni.getProperty("DB_TYPE")));
		ContrattoDAO contrattoDAO = daoFactory.getContrattoDAO();
		try {
			contrattoDAO.insert(contratto,Integer.parseInt(getRequestAttributes().get("id").toString()));
		} catch (SQLException e) {
			e.printStackTrace();
		}

	}

	@Get
	public Contratto retriveByCodice() {
		DAOFactory daoFactory = DAOFactory.getDAOFactory(Integer.parseInt(Impostazioni.getProperty("DB_TYPE")));
		ContrattoDAO contrattoDAO = daoFactory.getContrattoDAO();
		Contratto contratto;
		try {
			contratto = contrattoDAO.retriveById(Integer.parseInt(getRequestAttributes().get("id").toString()));
		} catch (NumberFormatException e) {
			return null;
		} catch (SQLException e) {
			return null;
		}
		return contratto;
	}

	@Put
	public void update(Contratto contratto) {
		DAOFactory daoFactory = DAOFactory.getDAOFactory(Integer.parseInt(Impostazioni.getProperty("DB_TYPE")));
		ContrattoDAO contrattoDAO = daoFactory.getContrattoDAO();
		try {
			contrattoDAO.update(contratto);
		} catch (SQLException e) {
			e.printStackTrace();
		}

	}

	@Delete
	public void delete(Contratto contratto) {
		DAOFactory daoFactory = DAOFactory.getDAOFactory(Integer.parseInt(Impostazioni.getProperty("DB_TYPE")));
		ContrattoDAO contrattoDAO = daoFactory.getContrattoDAO();
		try {
			contrattoDAO.delete(Integer.parseInt(getRequestAttributes().get("id").toString()));
		} catch (NumberFormatException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			e.printStackTrace();
		}

	}

}
